

# **Hands-on RTL Design**

Buy

## 1 Perf Counters

Question Solution Video Discussion

You are working on the next generation Processor unit and are responsible for designing the CPU performment of counters which can be programmed to be triggered on an event from different CPU units.

Design the base counter module which can be instantiated depending on the implemented number of surface received from the CPU pipeline. The counter output should only be accessible to software reads and thus mandate that after the read is complete the counter should reset the value to 0. Both software read and have any protocol requirements.

The width of the counter is parameterizable.

All the flops should be positive edge triggered with asynchronous resets (if any).

#### **Interface Definition**

sw\_req\_i : Software read request to the counter. Will read the `p\_count\_o` va

cpu\_trig\_i : CPU trigger event to the counter

p\_count : Performance counter read value to software. Should be zero when the

request in progress

#### Sample Simulation



### **Explanation**

On reset the counter value should be zero which is what is reflected in the p\_count\_o signal. The count on p\_count\_o interface once the software read request is seen. The counter resets to zero one cycle aft protocol requirement.

ı Bug

**Next Module** 

>\_ Console

**Run Testcases** 

**Submit** 

1 of 1 20-10-2023, 15:51